﻿// 麻省理工学院许可证
//
// 版权所有 (c) 2021-2023 zuohuaijun，大名科技（天津）有限公司  联系电话/微信：18020030720  QQ：515096995
//
// 特此免费授予获得本软件的任何人以处理本软件的权利，但须遵守以下条件：在所有副本或重要部分的软件中必须包括上述版权声明和本许可声明。
//
// 软件按“原样”提供，不提供任何形式的明示或暗示的保证，包括但不限于对适销性、适用性和非侵权的保证。
// 在任何情况下，作者或版权持有人均不对任何索赔、损害或其他责任负责，无论是因合同、侵权或其他方式引起的，与软件或其使用或其他交易有关。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace Jim.Web.Core;

public class DotliquidCustomFilter
{
    public static string test(string value, bool isString = true, char split = ',')//, int startIndex, int length = -1
    {
        if (string.IsNullOrWhiteSpace(value)) return "";
        string where = string.Empty;
        var items = value.Split(',');
        List<string> list = new List<string>();
        foreach (var item in items)
        {
            if (!string.IsNullOrWhiteSpace(item))
            {
                if (isString)
                    list.Add($"'{item}'");
                else
                    list.Add($"{item}");
            }
        }
        if (list.Any())
            where = string.Join(",", list);


        Console.WriteLine($"正在执行DotliquidCustomFilter.test  {value}  ->  {where}");
        return where;

        //if (length >= 0)
        //    return value.Substring(startIndex, length);
        //return value.Substring(startIndex);
    }


    public static string InNumber(string values)
    {
        string where = string.Empty;
        var items = values.Split(',');
        List<string> list = new List<string>();
        foreach (var item in items)
        {
            if (!string.IsNullOrWhiteSpace(item))
                list.Add(item);
        }
        if (list.Any())
            where = string.Join(",", list);
        Console.WriteLine($"正在执行DotliquidCustomFilter.InNumber  {values}  ->  {where}");
        return where;
    }

    public static string InString(string values)
    {

        string where = string.Empty;
        var items = values.Split(',');
        List<string> list = new List<string>();
        foreach (var item in items)
        {
            if (!string.IsNullOrWhiteSpace(item))
                list.Add($"'{item}'");
        }
        if (list.Any())
            where = string.Join(",", list);
        Console.WriteLine($"正在执行DotliquidCustomFilter.InString  {values}  ->  {where}");
        return where;
    }
    /// <summary>
    /// 拼接sqlserver in 语句
    /// BuildInSql( "a.FStatus","A,B,C") 拼接后 where a.FStatus in ('A','B','C')
    /// </summary>
    /// <param name="fieldName">字段名</param>
    /// <param name="values">字符串值，如A,B,C或者1,2,3</param>
    /// <param name="isString">是否字符串值，默认是</param>
    /// <param name="split">分割字符串，默认,</param>
    /// <returns></returns>
    public static string BuildInSql(string values, bool isString = true, char split = ',')
    {
        string where = string.Empty;
        var items = values.Split(',');
        List<string> list = new List<string>();
        foreach (var item in items)
        {
            if (!string.IsNullOrWhiteSpace(item))
                list.Add(isString ? $"'{item}'" : item);
        }
        if (list.Any())
            where = string.Join(",", list);
        Console.WriteLine($"正在执行DotliquidCustomFilter.BuildInSql  {values}  ->  {where}");
        return where;
    }
}
